$(function () {
  let layer = layui.layer
  // 1.1 获取裁剪区域的 DOM 元素
  var $image = $('#image')
  // 1.2 配置选项
  const options = {
    // 纵横比
    aspectRatio: 1,
    // 指定预览区域
    preview: '.img-preview'
  }

  // 1.3 创建裁剪区域
  $image.cropper(options)

  // 创建点击事件
  $("#btnChooseImage").on("click", function (e) {
    $("#file").click()
  })

  // 为文件选择框绑定 change 事件
  $("#file").on('change', function (e) {
    // 获取用户选择的文件
    let filelist = e.target.files
    if (filelist.length === 0) {
      return layer.msg('请选择照片！')
    }

    // 拿到用户选择的文件
    let file = e.target.files[0]
    // 根据选择的文件，创建一个对应的URL地址
    let ImgURL = URL.createObjectURL(file)

    $image
      .cropper('destroy')      // 销毁旧的裁剪区域
      .attr('src', ImgURL)  // 重新设置图片路径
      .cropper(options)        // 重新初始化裁剪区域
  })

  // 为上传头像添加点击事件
  $("#btnUpload").on("click",function(e){
    let dataURL = $image
      .cropper('getCroppedCanvas', { // 创建一个 Canvas 画布
        width: 100,
        height: 100
      })
      .toDataURL('image/png')       // 将 Canvas 画布上的内容，转化为 base64 格式的字符串
      
      $.ajax({
        method:'POST',
        url:'/my/update/avatar',
        data:{
          avatar: dataURL
        },
        success: function(res){
          if(res.status!==0){
            return layer.msg('更换头像失败！')
          }
          layer.msg('更换头像成功！')
          window.parent.getUserInfo()
        }
      })
    })
})